home *** CD-ROM | disk | FTP | other *** search
/ Die Ultimative Software-P…i Collection 1996 & 1997 / Die Ultimative Software-Pakete CD-ROM fur Atari Collection 1996 & 1997.iso / g / gnu_c / crssrc16.zoo / src / deleteln.c < prev    next >
Encoding:
C/C++ Source or Header  |  1991-09-27  |  1.6 KB  |  58 lines

  1. /*
  2.  * Copyright (c) 1981 Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms are permitted
  6.  * provided that the above copyright notice and this paragraph are
  7.  * duplicated in all such forms and that any documentation,
  8.  * advertising materials, and other materials related to such
  9.  * distribution and use acknowledge that the software was developed
  10.  * by the University of California, Berkeley.  The name of the
  11.  * University may not be used to endorse or promote products derived
  12.  * from this software without specific prior written permission.
  13.  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
  14.  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
  15.  * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  16.  */
  17.  
  18. #ifndef lint
  19. static char sccsid[] = "@(#)deleteln.c    5.3 (Berkeley) 6/30/88";
  20. #endif /* not lint */
  21.  
  22. # include    "curses.ext"
  23.  
  24. /*
  25.  *    This routine deletes a line from the screen.  It leaves
  26.  * (_cury,_curx) unchanged.
  27.  *
  28.  */
  29. int wdeleteln(win)
  30. reg WINDOW    *win;
  31. {
  32.     reg char    *temp;
  33.     reg int        y;
  34.     reg char    *end;
  35.  
  36. # ifdef DEBUG
  37.     fprintf(outf, "DELETELN(%0.2o)\n", win);
  38. # endif
  39.     temp = win->_y[win->_cury];
  40.     for (y = win->_cury; y < win->_maxy - 1; y++) {
  41.         if (win->_orig == NULL)
  42.             win->_y[y] = win->_y[y + 1];
  43.         else
  44.             bcopy(win->_y[y + 1], win->_y[y], win->_maxx);
  45.         touchline(win, y, 0, win->_maxx - 1);
  46.     }
  47.     if (win->_orig == NULL)
  48.         win->_y[y] = temp;
  49.     else
  50.         temp = win->_y[y];
  51.     for (end = &temp[win->_maxx]; temp < end; )
  52.         *temp++ = ' ';
  53.     touchline(win, win->_cury, 0, win->_maxx - 1);
  54.     if (win->_orig == NULL)
  55.         _id_subwins(win);
  56.     return OK;
  57. }
  58.